import axios from 'axios'
import ElementUI from "element-ui";
import store from "../store"
import Vue from 'vue'
const request = axios.create({
  /**
   * 注意！！ 这里是全局统一加上了 '/api' 前缀，也就是说所有接口都会加上'/api'前缀在，
   * 页面里面写接口的时候就不要加 '/api'了，否则会出现2个'/api'，
   * 类似 '/api/api/user'这样的报错，切记！！！
   */
  baseURL: '/api', timeout: 50000 // 超时设置
})

// request 拦截器
// 可以自请求发送前对请求做一些处理
// 比如统一加token，对请求参数统一加密
request.interceptors.request.use(config => {
  // debugger
  config.headers['Content-Type'] = 'application/json;charset=utf-8'
  let token = localStorage.getItem("token")
  if (token != null && token != "") {
    config.headers['token'] = token // 设置请求头
  } else {
    config.headers['token'] = '' // 设置请求头
  }
  return config
}, error => {
  return Promise.reject(error)
});

// response 拦截器
// 可以在接口响应后统一处理结果
request.interceptors.response.use(response => {
  console.log('结果返回',response)
  let res = response.data;
  //为了防止其他请求把真正需要遮罩层的请求覆盖掉
  if(window.loadingObj) {
    window.loadingObj.close();
  }
  if(window.loadingObj_getOne) {
    window.loadingObj_getOne.close();
  }
  // 当用户状态异常或者token无效时，直接退出登录
  if (res.code === 10000 || res.code === 1000 ) {
    ElementUI.Message({
      message: res.message, type: 'error'
    })
    store.dispatch("staff/logout").then(r => {
    })
    return Promise.reject()
  }

  // 如果是返回的文件
  if (response.config.responseType === 'blob') {
    return res
  }
  // 兼容服务端返回的字符串数据
  if (typeof res === 'string') {
    res = res ? JSON.parse(res) : res
    return res
  }

  if (response.data.code && response.data.code != 200 ) {
    ElementUI.Message({
      message: response.data.message, type: 'error'
    })
    return Promise.reject()
  }

  return res;
}, error => {
  ElementUI.Message({
    message: '服务器异常！', type: 'error'
  });
  console.log(error)
  //location.href = "/login"
  // ElementUI.$message.error(error.response.data.message);
  //为了防止其他请求把真正需要遮罩层的请求覆盖掉
    if(window.loadingObj) {
      window.loadingObj.close();
    }
    if(window.loadingObj_getOne) {
      window.loadingObj_getOne.close();
    }
  return Promise.reject(error)
})


export default request


